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1 

Data Routing in a Communication Network 

4 

The present invention relates to data routing in a 
communication network. More particularly, though not 
necessarily, the invention relates to a method and 
8 apparatus collecting charging information relating to 
Internet usage. 

Rackg-ronnd t-o thg H rtvgnt- i on 

12 

Typically, Information Service Providers (ISPs) provide 
their own information and interactive services to 
subscribers and additionally provide subscribers with a 
16 gateway access to the Internet and thereby to thousands 
of service providers around the world. Subscribers may 
also access the Internet and the thousands of smaller 
ISPs directly through smaller local ISPs. 

20 

The Internet comprises many communication links and 
networks interconnected by "routers". ISPs typically 
lease bandwidth on these links, networks, and routers 
24 from operators such as telecommunication operators and 
therefore need to recoup their outlays and make a profit 
by passing appropriate charges on to their subscribers. 

28 Generally, large ISPs bill their subscribers on a time- 
use basis, e.g. on a fee based on connection time, after 
a financial payment relationship has been established 
between the subscriber and the ISP. Similarly, smaller 

32 local ISPs also usually base their service charges to 
their subscribers for access to the Internet on a time- 
use basis. The smaller ISPs either do not charge for 
access to their information and interactive services or, 
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i 

if they do, also require the user to establish some sort 
of financial relationship. 

4 Internet users are identified in the Internet by 

Internet Protocol (IP) addresses which are reserved for 
the users or service providers . In charging users , the 
amount of actual packets sent and received is usually 
8 not considered, nor is the source of fetched packets . 
As already mentioned, fixed, time-use based, or 
packet/byte count based billing mechanisms exist today. 
Mechanisms for circuit -switched type bandwidth 
12 allocation and billing are being designed. 

Most circuit switched communication systems, e.g. 
conventional telephone networks, ATM networks, and so 

16 on, are able to perform billing based on distance (local 
versus long distance call) and on the basis that a 
connection is reserved and maintained for the duration 
of a call even though the data comprising the carried 

20 communication may pass over the link on an infrequent 
basis. However, the methods used for circuit switched 
communication are not directly applicable to packet 
switched communication used in the Internet, as there 

24 are no concepts equivalent to a "circuit" and to "the 
establishment of a call" . 

As such, Internet users have the freedom to access any 
28 part of the Internet with the same cost regardless of 
the distance to the accessed part. The cost of an 
overseas link is of course much higher than the cost of 
a local link. Consequently the capacity of the overseas 
32 link is often very limited. There exists no simple 
solution today which would allow an ISP or IAP to 
collect higher fees from those users that use long 
distance links more than others. 



36 
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Summary of f.he Tnvpnt-inn 

It is an object of the present invention to generate and 
4 record information of the links used by a service 

provider or the like, in order to provide destination 
based information regarding the connections that a user 
has made. 

8 

It is another object of the present invention to use 
link- state routing protocol information to determine 
whether or not a special-cost link is passed through on 
12 a data packet's journey through the Internet. 

According to a first aspect of the present invention 
there is provided a method of collecting charging 
16 information relating to usage of a packet-switched data 
network by a network user, the method comprising: 

constructing in a router of the network a routing 
table containing a set of destination address ranges and 
20 a set of respective next hop network nodes; 

assigning a cost class to at least one link or node 
of the data network; 

assigning to each address range in the routing 
24 table a cost class in dependence upon the links/nodes, 

and respective cost classes, through which a packet must 
travel to an address within the range; 

receiving a data packet from said network user and 
28 identifying its destination address; 

on the basis of the destination address, 
determining from the routing table the associated cost 
class; and 

32 incrementing a corresponding cost class counter. 

Preferably, the method comprises classifying destination 
address ranges into Low and High cost classes. The 
36 configuration of these classes may then be based on the 
simple listing of outgoing links by an Internet Service 
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Provider, instead of enumerating all possible 
destinations, e.g., on the national level. 

4 Multiple intermediate cost classes may also be defined. 
Such extensions require the keeping of separate 
packet/byte counters for each class. 

8 Separate billing for originating and terminating network 
connections may be made, since the network access node 
may follow traffic (TCP) to find out which side of the 
network has initiated the connection. Such control is 

12 already used for security purposes in firewalls. 

Further, UDP (User Datagram Protocol) traffic could be 
followed (again as in the firewalls) by considering 
incoming UDP packets to belong to a connection if they 

16 originate from an address to which outgoing packets have 
recently been sent. 

Embodiments of the invention have the advantage that 
20 information concerning a "destination" which a user has 
reached can be classified and the classification is 
relatively short. Billing based on real communication 
costs to the Service Provider and the user can be 
24 performed. In a simplest form, only one memory access 
to retrieve "High-cost" flags needs to be performed in 
addition to the normal routing decision. No extra 
network traffic is created. 

28 

The configuration of High and Low cost destinations uses 
a very simple list of links, instead of enumerating a 
long and often changing list of destinations. 

32 

The solutions can be locally implemented in one Service 
Provider, without the need for similar techniques in 
other parts of the Network. 

36 
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The invention is particularly applicable to the 
Internet, where a user accesses the open Internet 
through an Internet Service Provider (ISP) . Preferably, 
4 the routing table containing the assigned cost classes 
is provided in a Network Access Server (NAS) of the ISP 
through which the user accesses a Local Area Network of 
the ISP. 

" 8 

It will be appreciated that the invention is applicable 
for collecting charging information relating to any 
packet switched data service. This includes WWW access, 
12 e-mail, Telnet, FTP etc. 

Preferably, a "map" of the data network (or a local 
region of the network, i.e. "autonomous" area) is 

16 constructed, using the OSPF protocol, to select the next 
hop for each group of destination addresses. On the 
basis of an identified shortest path, a cost class is 
allocated to the path and hence to the associated 

20 destination address range. 

According to a second aspect of the present invention 

there is provided apparatus for collecting charging 
24 information relating to usage of a packet-switched data 

network by a network user, the apparatus comprising: 
a router in said the network having a memory 

storing a routing table containing a set of destination 
28 address ranges and a set of respective next hop network 

nodes ; 

first processing means for assigning a cost class 
to at least one link or node of the data network; and 

32 second processing means associated with said router 

and arranged to assign to each address range in the 
routing table a cost class in dependence upon the 
links/nodes, and respective cost classes, through which 

36 a packet must travel to an address within the range, 



WO 99/00946 



PCT/FI98/00496 



6 

the router being arranged in use to receive a data 
packet from said network user, to identify its 
destination address, and on the basis of the destination 
4 address to determine from the routing table the 
associated cost class, 

the apparatus further comprising a set of counters 
corresponding to respective cost classes and means for 
8 incrementing the cost class counter corresponding to the 
determined cost class. 

Ryjftf D^Kcr-H pi-ion of hbp Drawi ng.g 

12 

For a better understanding of the invention and in order 
to show how the same may be carried into effect 
reference will now be made, by way of example, to the 
16 accompanying drawings, in which: 

Figure 1 is a block diagram of a system showing 
access facilities to the Internet; 

Figure 2 is a block diagram showing in more detail 
20 an Internet Service Provider of the system of Figure 1/ 
and 

Figure 3 is a flow diagram of a method of charging 
in the Internet Service Provider of Figure 2 . 

24 

Dfita-ilfiH npsrripl- i on of fpnain Rmhori i mpnh a 

In Figure 1, a single ISP 1 is shown connected on the 
28 Internet 2. It should be understood that thousands of 
ISP's all over the world are connected to the Internet 
and are arranging accesses to the multitude of users 
having access to the Internet . Connection between the 
32 ISP 1 and the Internet 2 is over a digital Ethernet 

transmission line 3 or other high speed transmission. A 
user desiring access to the information and/or 
interactive services available over the Internet from 
36 ISP 1 may be an individual who accesses the Internet 

through a fixed terminal 4 . Terminal 4 is connected to 



WO 99/00946 



PCT/FI98/00496 



over a POTS (Plain Old Telephone System) connection 5 to 
the user's Local Exchange (LE) 6 or a Transit Exchange 
(TE) 7 through a modem (not shown in Figure 1) . The LEs 
4 and TEs 6,7 are interconnected by trunk lines 12. From 
the exchange (s) 6,7 a connection is made to ISP 1. 

It will be understood that other Internet users may 
8 reach the Internet 2 through a fixed connection 8 from a 
company Local Area Network (LAN) 9 using ATM or the 
like. Small companies 10 may also have a limited number 
of connections to the Internet 2 via call connections 
12 through a PBX (Public telephone Exchange) 11. 

Additionally, subscribers 13 to a digital cellular radio 
telephone network, comprising base stations 14, mobile 
switching centre 15, and connections 16,17 may access 
16 the Internet through the same ISP 1 . 

Figure 2 presents in more detail the ISP 1 of Figure 1 
and its connections to the telecommunications network 

20 and to the Internet 2 . A subscriber connects to a 

Network Access Server (NAS) 18 of the ISP 1 via a modem 
pool 19, ISDN access 20, asymmetric data subscriber line 
(ADSL) connection 21, or xDSL connection (not shown), of 

24 the LE or TE 6,7 (these components may be integrated 
into the NAS) . The NAS 18 interfaces the circuit 
switched transmission on the telecommunications side to 
packet switched transmission on the Internet side. 

28 Typically a Point-to-Point Protocol (PPP - IETF RFC 

1661) connection is established between the subscriber 
terminal 4 and the NAS 18. The NAS 18 also provides for 
the initial routing of data packets toward their final 

32 destinations. 

The ISP 1 typically comprises many additional 
interconnected routers 22 which may be located near one 
36 another or which may be geographically dispersed. These 
routers convey data packets onwards to links 23 leading 
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from the ISP to external networks. The links may 
include a local link to a local network 24, a national 
link to a national network 25, an international link to 

4 a neighbouring national network 26, and an 

intercontinental link to national networks 27 of another 
continent . The ISP 1 may also be linked to other ISPs 
(usually employing ATM) although these links are not 

8 shown in Figure 2 . 

Within the ISP 1, local Web servers 2 8 may be connected 
to certain of the NASs/routers in a Local Area Network 
12 (LAN) . These severs act as Internet content providers . 
The ISP 1 also has one or more proxy servers 2 9 the 
purpose of which is well known but which will in any 
case be described below. 

16 

A data packet is routed in the ISP 1 and elsewhere in 

the Internet 2 on the basis of a specified IP address. 

This address is a 3 2 -bit address assigned to hosts 
20 participating in a TCP/IP Internet, and consists of a 

network portion and host portion. This partition makes 

for efficient routing. Internet users will be more 

familiar with Domain Name addresses, e.g. 
24 "www.ericsson.co", although these correspond to IP 

addresses with the conversion being done within the ISP 

1 . 

28 Every router in the Internet 2, including those routers 
22 controlled by the ISP 1 and the NAS 18, are provided 
with so-called routing tables. A routing table contains 
a list of IP address groups, together with a list of 

32 respective nodes (i.e. routers, hosts, etc) 

corresponding to a next hop for a. data packet. A 
routing table may have the following form: 



destgrpl 


nxthopl 


destgrp2 


nxthop2 
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destgrp3 


nxthop3 


destgrp4 


nxthop4 



where "destgrp#" identifies a range of IP addresses and 
"nxthop#" identifies a router which is directly 

4 connected to the router in which the routing table is 

stored. When a data packet is received by a router, the 
routing table is searched, on the basis of the 
associated IP address, to identify the next router in 

8 the chain. 

Routing tables are not static, but rather are 
dynamically modified to reflect changes in the physical 

12 and operational structure of the Internet. For a given 
destgrp, a router uses a protocol termed Open Shortest 
Path First (OSPF - IETF RFC 1583) to determine the nxthp 
based upon information received by the router from other 

16 connected routers . 

Despite the fact that a routing table only contains the 
next hop for a given IP address range, a router 

20 nevertheless requires an internal "map" of the 

surrounding Internet region to determine that next hop. 
Considering the ISP 1 of Figure 2, the map constructed 
by the NAS 18 may include the ISP network together with 

24 the boundary crossing links 23. It will be understood 
therefore that using this map it is possible to 
determine the types of links which a data packet, 
directed to an IP address within a given address range 

28 (destgrp#) , will or is likely to pass through. 

For the purpose of the present example, Internet links 
are classified into two cost types, High and Low cost. 
32 These are defined in a fixed list in a memory of the NAS 
18. High cost links are those links which connect the 
ISP network to foreign networks 2 6,27 whilst low cost 
links connect to local and national networks 24,25 and 
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to other ISPs and IAPs . Links within the ISP 1 are also 
classified as Low cost links. Cost classes are stated 
in a third column added to the routing table (indicated 
4 by reference numeral 3 0 in Figure 2) of the NAS 18, and 
indicate whether or not a data packet routed to an 
address contained within the destgrp will pass through a 
High cost link or not. For example: 

8 



destgrpl 


nxthopl 


High 


destgrp2 


nxthopl 


Low 


destgrp3 


nxthop3 


Low 


destgrp4 


nxthop4 


Low 


destgrp5 


nxthopB 


High 



It will be appreciated that the destgrps may be 
subdivided, compared to those contained in conventional 

12 routing tables, where certain subgroups are associated 
with High cost links and others are not. For example, 
destgrpl and destgrp2 both share the same nxthop, but 
are classified differently in the cost column of the 

16 table. 

As has already been described, conventional Internet 
billing systems provide for charging a subscriber on the 

20 basis of time-use and on number of packets sent. The 
latter is carried out using a packet counter contained 
in the NAS 18 . In order to take advantage of the 
information contained in column 3 of the modified 

24 routing table, a pair of counters are included in the 

NAS 18. A first of the counters 31 maintains a count of 
the number of packets forwarded by the NAS 18 through at 
least one High cost link whilst the other counter 3 2 

28 maintains a count of other forwarded data packets. It 
will be appreciated that the NAS 18 has details of the 
source of data packets, i.e. subscriber details, and is 
therefore able to provide billing information to the ISP 

32 billing collector (not shown in Figure 2) . 



WO 99/00946 PCT/FI98/00496 

11 

Alternatively, the NAS 18 may send billing information 
to a billing collector of the telephone network. 

4 The method described above is further illustrated in the 
flow diagram of Figure 1 (steps 10 0 to 107) . 

Instead of using the OSPF protocol map to determine 
8 destgrp cost classes, the NAS 18 may use "dummy" packet 
transmissions to trace the route through the Internet to 
a destination. Internet protocols such as ICMP 
(referred to in IETF - RFC 13 93) and employed by 

12 programs such as TRACEROUTE may be used for this 

purpose. However, this implementation creates some 
additional network traffic every time a user connects to 
a new server in the Internet, and incurs an additional 

16 hashing operation on every packet. Despite its 

disadvantages, route tracing may be employed where link 
state routing information is not available. If it is 
initially not known if a destination address is reached 

20 through a High cost link, the trace program can initiate 
a trace to identify this information. 

The provision of a proxy server 29 in the ISP 1 has 
24 already been mentioned. The proxy server 2 9 retains Web 
pages downloaded by subscribers for some predetermined 
time. The address of the proxy server 29 is configured 
in subscribers' Web browsers such that all Web page 
28 fetches go first to the proxy server 29. The Server 29 
inspects its memory for each request and provides the 
requested page form its own memory if it is stored 
there. Otherwise, the proxy server 2 9 fetches the page 
32 from the Internet in the normal manner. 

The billing mechanism described above may be expanded to 
encompass the proxy server 29. In particular, if a Web 
36 page requested by a subscriber is not already contained 
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in the memory of the proxy server 29, the fetch request 
is analysed with the mechanisms presented above, and 
thus it becomes clear if the request must go through a 
4 High cost link or not. The proxy server 29 collects the 
information and later communicates it to the ISP ! s 
billing system. 

8 If it is desired that a subscriber is charged regardless 
of whether or not the requested page is found in the 
proxy server 29, the server 29 can add a cost flag to 
each Web page stored in its memory. The cost of these 

12 pages can then be added to a subscriber's bill even 

though the pages were actually downloaded from the proxy 
server 29. The cost of retrieving the document from a 
high cost link may alternatively be recovered by 

16 subdividing it between all of the subscribers who 
download the page from the proxy server 29. 

Separate billing for originating and terminating TCP 
20 connections could be made. This is possible since the 
NAS 18 can follow the TCP-level traffic to find out 
which side has initiated the connection. Such control 
is already used for security purposes in firewalls. 
24 Similarly, UDP traffic could be followed (again as in 
the firewalls) , by considering incoming UDP packets to 
belong to a connection if they originate from an address 
to which outgoing packets have recently been sent. 

28 

A firewall system can be used to control the access to 
the global Internet and the user can enable or disable 
the access through an applet linked with a billing 

32 system. The solutions presented here could be combined 
with such architectures, by allowing multiple levels of 
accesses: local servers, national access, continental 
access, international access, and so on. The 

36 configuration of these levels would then be based on the 
listing of outgoing links from the access node, instead 
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of enumerating all possible destinations, e.g. on the 
national level. With the firewall it is understood that 
data packets are filtered when arriving at a screening 
4 system of the router connected between two networks in 
order to determine from the packet contents whether or 
not it is of a type to be passed to the second network. 

8 It is understood to that the ISP network and routers are 
normally protected by suitable firewalls and source 
address filters. In the absence of these, Internet 
users might be able to subvert the routing protocols or 
12 ICMP packets. Firewalls within the ISP network should 
however be able to pass the trace program and routing 
protocol packets . 

16 It will be appreciated by the person of skill in the art 
that modifications may be made to the above described 
embodiments without departing from the scope of the 
present invention. For example, whilst the modified 

20 routing table, containing the cost classifications, has 
been described as being implemented in the NAS 18 of the 
ISP 1, it may alternatively, or additionally, be 
provided in one or more of the routers 22 . A modified 

24 billing system may then be used to collect charging 

information from the various distributed counters. In 
another modification, links may be classified into more 
than the two classes (High and Low) indicated above. 

28 For example, national links may be classified as Medium 
cost links. 

The embodiment described above is concerned with billing 
32 subscribers on the basis of outgoing packets. If 

desired, the NAS 18 (or other router 22) can perform 
billing on the basis of incoming data packets, based on 
the source address of the packet. However, this will 
36 incur an additional cost roughly equivalent to the 
routing decision for one packet. 
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CI aimff 

1. A method of collecting charging information 

4 relating to usage of a packet -switched data network by a 
network user, the method comprising: 

constructing in a router of the network a routing 
table containing a set of destination address ranges and 
8 a set of respective next hop network nodes; 

assigning a cost class to at least one link or node 
of the data network; 

assigning to each address range in the routing 
12 table a cost class in dependence upon the links/nodes, 

and respective cost classes, through which a packet must 
travel to an address within the range; 

receiving a data packet from said network user and 
16 identifying its destination address; 

on the basis of the destination address, 
determining from the routing table the associated cost 
class; and 

20 incrementing a corresponding cost class counter. 

2. A method according to claim 1, wherein the data 
network is the Internet, and a user accesses the 

24 Internet through an Internet Service Provider. 

3. A method according to claim 2, wherein the routing 
table containing the assigned cost classes is provided 

28 in a Network Access Server (NAS) of an Internet Service 
Provider through which the user accesses a Local Area 
Network of the ISP. 

32 4 . A method according to claim 2 or 3 , wherein the 
routing table is constructed using OSPF protocol to 
select the next hop for each group of destination 
addresses and, on the basis of an identified shortest 

36 path, a cost class is allocated to the path and hence to 
the associated destination address range. 
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5. Apparatus for collecting charging information 
relating to usage of a packet-switched data network by a 

4 network user, the apparatus comprising: 

a router in said the network having a memory 
storing a routing table containing a set of destination 
address ranges and a set of respective next hop network 

8 nodes; 

first processing means for assigning a cost class 
to at least one link or node of the data network; and 

second processing means associated with said router 
12 and arranged to assign to each address range in the 
routing table a cost class in dependence upon the 
links/nodes, and respective cost classes, through which 
a packet must travel to an address within the range, 
16 the router being arranged in use to receive a data 

packet from said network user, to identify its 
destination address, and on the basis of the destination 
address to determine from the routing table the 
20 associated cost class, 

the apparatus further comprising a set of counters 
corresponding to respective cost classes and means for 
incrementing the cost class counter corresponding to the 
24 determined cost class. 

6. A method for creating information concerning the 
connections accessed by a user in a communications 

28 network and comprising the steps of : 

initiating the connection to the data network; 

connecting the user's computer to the data network; 

communicating with hosts in the data network; 
32 creating destination information; 

classifying the destination information to 
different types; 

comparing the addresses of the contacted hosts with 
36 the type information; and 
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combining the type information with the user 
information for further processing. 

4 7. A method of creating the information and/or services 
provided to a user in a communications network and 
comprising the steps of: 

initiating the connection to a provider's number; 
8 creating the connection to the provider's router in 

order to access the Internet through the provider; 
connecting to the Internet; 

communicating with the hosts in the Internet; 
12 creating the destination information; 

classifying the destination information to 
different types; 

comparing the addresses of hosts with the type 
16 information; and 

combining the type information to the user 
information for billing purposes the user according to 
the type of the host . 

20 

8 . A system for creating information of the connections 
user accessed by a user in a communications network 
wherein; 

24 the connection is initiated to a service provider's 

number by the user's computer; 

the connection is created from the user's computer 
to the provider's router in order to access the Internet 
28 through the provider, the user computer is connected to 
the Internet; 

the user is communicating with the hosts in the 
Internet ; 

32 the destination information is created according to 

the user usage ; 

the destination information is classified to 

different types, 
36 the addresses of hosts is compared with the type 

information; and 
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the type information is combined with the user 
information for further processing. 



WO 99/00946 



PCT/FI98/00496 




WO 99/00946 



PCT/FI98/00496 




WO 99/00946 



PCT/FI98/00496 



3/3 



Begin 




Step 100 



At NAS, construct autonomous area connectivity map using OSPF protocol 



Step 101 



Construct routing table in NAS 



Classify destgrps in routing table as High or Low cost using 
connectivity map and include class in routing table 




Step 102 



Step 103 



1 

Receive data pad 
and identify desti 


t 

tet from subscriber / 
nation address 






Identify corresponding destgrp in 
routing table and associated cost class 

i 




Step 104 



Step 105 



Increment corresponding cost class counter in NAS 




Step 106 



End 



Step 107 



Figure 3 



